FORM PTO-1082 



' ®ifif ' s PT0 

12/27/99 

>R PATEIvfrS 



PATE 



BOX PATENT APPLICATION 

ASSISTANT COMMISSIONER FOR f 
Washington, D.C. 20231 

Sir: 

Transmitted herewith for filing is the patent application of 

Inventor(s): Paul H. Stallings, Barton Stander, and Yunching Huang 

For (Title): Method For Transforming CAD Model Using General Function Composition Mechanism 
Enclosed are: 



*ATENT 

Attorney Docket No. 31408-10229 



[X] 
[ ] 
[ ] 
[ ] 
[X] 

[ ] 



sheets of informal drawings. 



An assignment of the invention to 
A certified copy of a 



An associate power of attorney. 

A verified statement to establish small entity status under 37 CFR 1.9 and 37 CFR 1.27. 



Applicants) claim convention priority under 35 U.S.C. 119 based on , 
Serial No. filed 





o 



. application 





(Col. 1) 


(Col. 2) 


fU FOR: 


NO. FILED 


NO. EXTRA I 


Ui BASIC FEE 






* OTAL CLAIMS 


1 - 20 


0 


ST. DEP. CLAIMS 


1 - 3 


0 


>1j -j MULTIPLE DEPENDENT CLAIM PRESENTED 



SMALL ENTITY 



OTHER THAN A 



m 

[X] 



ihe difference in Col. 1 is less than zero, enter "0" in Col, 2. 

Please charge Deposit Account No. 1 0-0460 in the amount of $ 380.00 



RATE 


FEE 




$ 380.00 


x 9= 




x 39= 




+ 130= 


$' 


TOTAL 


$ 380.00 





SMALL ENTITY 


OR 


RATE 


FEE 


OR 




$ 760.00 


OR 


x 18= 


S 


OR 


x 78= 


$ 


OR 


+ 260= 


$ 


OR 


TOTAL 


$ 



[ ] 

[X] 



[XI 



Two additional copies of this sheet are enclosed. 

A check in the amount of $ to cover the filing fee is enclosed. 

The Commissioner is hereby authorized to charge payment of the following fees associated with this communication or credit any 
overpayment to Deposit Account No. 10-0460. Two additional copies of this sheet are enclosed. 
[X] Any additional filing fees required under 37 CFR 1.16. 

[X] Any patent application processing fees under 37 CFR 1.17. 

The Commissioner is hereby authorized to charge payment of the following fees during the pendency of this application or credit any overpayment 
to Deposit Account No. 10-0460. Two additional copies of this sheet are enclosed. 
[X] Any patent application processing fees under 37 CFR 1.17. 

[ ] The issue fee set in 37 CFR 1 . 1 8 at or before mailing of the Notice of Allowance, pursuant to 37 CFR 1 .31 1 (b). 
[X ] Any filing fees under 37 CFR 1 . 1 6 for presentation of extra claims. 



Dated December 27, 1999 



Eric H. Weimers 



station of extra claims. 



Attorney of Record 



Reg. No. 33,048 



CERTIFICATE OF "EXPRESS MAIL" UNDER 37 CFR 1.10 



"EXPRESS MAIL" Mailing Label Number EG579618604US 



Date of Deposit December 27, 1999 



I hereby certify that this paper or fee is being deposited with the United States Postal Service "Express Mail Post Office to Addressee" service 
under 37 CFR 1.10 on the date indicated above and is addressed to the Commissioner of Patents and Trademarks, Washington, D.C. 20231. 



(Typed 



?ed or Printed Name of Person Ma* 



ing Paper or Fee) 



— ) (Signature ofP&rfi 



son Mailing Pape^or Fee) 



408494 



JENNER& BLOCK • ONE IBM PLAZA • CHICAGO, IL 60611 • (312)222-9350 



Application Transmittal 



METHOD FOR TRANSFORMING CAD MODEL USING GENERAL 
FUNCTION COMPOSITION MECHANISM 



FIELD OF THE INVENTION 
5 The invention relates to the field of Computer Aided Design (CAD) 

applications, and more particularly, to transforming the geometry of procedural 
models within CAD applications by using a generalized function composition 
mechanism allowing transformation with arbitrary functions. 

1 0 BACKGROUND OF THE INVENTION 

Alteration of the geometry of a model has been known in the art. Common 
applications of geometry transformation include moving, scaling and rotating models, 
which merely apply a linear transformation to the model's geometry. Nothing in 
these simple transformations indicated the use of arbitrary function composition to 
15 perform more complicated, arbitrary transformations. 

Geometric transformation using a single specific function is also known in the 
art. For example, U.S. Patent No. 4,821 ,214 to Sederberg [Sederberg] demonstrates 
the transformation of a model defined by a grid of control points by a single specific 
20 function. [Sederberg] does not indicate the ability to perform a transformation using 
any arbitrary function, and [Sederberg] does not disclose defining the model using 
procedural surfaces, curves and positions to allow arbitrary function composition. In 
order to define a shape, [Sederberg] requires the user to define a set of control points 
that approximate the shape. In order to achieve accuracy required for many 
25 operations such as Computer Aided Manufacturing (CAM), a large number of control 
points must be defined which makes working with the model difficult. [Sederberg] 
does not disclose representing the geometry of a shape as a set of functions which 
allow for more accurate and easier manipulation. 

30 Similarly, the Pro-Engineer CAD modeling product by Parametric 

*j Technologies Corporation [PTC] contains a bend function which allows a user to 

perform a specific, pre-defined bend transformation function. Nothing in [PTC] 
discloses using a general function composition mechanism to allow transformation 
with an arbitrary, user-defined function. 

35 

Because of the limitations of the prior art, there exists a continuing need to 
allow geometric transformation in CAD applications using a generalized mechanism 
for applying arbitrary functions. 

40 SUMMARY OF THE INVENTION 

The present invention overcomes the limitations of the prior art by providing 
methods for accurately transforming CAD models represented by procedural curves 
and surfaces through a general function composition mechanism allowing 
transformation by any arbitrary function. 

45 It is an object of this invention to provide a general function composition 

mechanism to transform solid models represented as procedural curves and surfaces 
using any arbitrary function as a transformation function. A shape in a solid model 
consists of a topography and a geometry. The topography of the shape defines how 
the faces, edges and vertices of the shape connect to one another. The geometry of 
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the shape underlies those faces, edges and vertices with surfaces, curves and 
positions, respectively, which define the location in space of the set of points of the 
shape and its component parts. 

Because the surfaces and curves of the shape may be defined by a set of 
5 functions which map points from a domain space into 3 -dimensional space, space 
warping allows the geometry of a shape to be altered by an arbitrary transformation 
function without changing the topography of the shape.. These underlying functions 
may be transformed through function composition with the transformation function 
into new surface and curve functions. The positions of the original shape may simply 
10 be passed through the transformation function to provide the positions of the new 
shape. The new geometry of the shape may be determined by passing each point in 
the domain of each of the original surface and curve functions through that function's 
corresponding new composed function. The resulting set of points represents the 
geometry of the new shape. 

15 It is a further object of this invention to provide an easy, interactive 

mechanism for allowing a user to transform solid models using an arbitrary 
transformation function. In order to provide this interactivity, the original shape is 
first displayed to the user. The user may then define a function with which to 
transform the shape. Once the shape has been transformed, the resulting shape is 

20 shown to the user. The user may then keep the transformed shape or refine the 
transformation function further. 

It is a further object of this invention to allow the user to accurately perform 
specific transformations representing structural deformations of an object, such as 
bending, twisting or stretching the object, by transforming the functions representing 
25 the geometry of the object. 

BRIEF DESCRIPTION OF THE DRAWINGS 
FIG. 1 : Diagram of initial CAD model of shape 
FIG. 2: Diagram of model after complex warp of shape. 
FIG. 3: Diagram of model after bend warp. 
30 FIG. 4: Schematic diagram illustrating bend warp changing geometry. 
FIG. 5: Process flow diagram of space warping method. 
FIG. 6: Diagram of model after twist warp. 
FIG. 7: Diagram of model after stretch warp. 

35 DETAILED DESCRIPTION OF THE INVENTION 

L Introduction 

Space warping is the process of applying a transformation of three- 
dimensional Euclidean space, or 9? 3 to SR 3 , to a CAD model. A CAD model is a 

40 computer model of an object that is represented by a set of faces, edges and vertices. 
The faces have underlying them surfaces, the edges have underlying them curves, and 
the vertices are at given positions in space. The faces, edges and vertices of a CAD 
model are called the topology of the model. The surfaces, curves and positions are 
called the geometry of the model. The topology of the model indicates how the faces, 

45 edges and vertices of the model connect to each other, while the geometry of the 
model indicates the location of the points underlying the model and its component 
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parts in space. Space warping is a process by which the geometry of a model is 
changed leaving the topology the same. 

The present invention allows accurate transformation of a CAD model by an 
arbitrary function using a generalized transformation mechanism. The method may 
be applied to shape representations that are commonly used in CAD applications and 
reduces the problem of transformation to the composition of the transformation 
function and the surface functions, curve functions, and positions underlying the 
initial shape representation. 



The methods discussed herein must be performed in a solid modeler. A solid 
modeler that is suitable for performing the methods discussed herein is ACIS 
Geometric Modeler which is commercially available from Spatial Technology Inc., 
Boulder, Colo. ACIS is written in C++. Specific embodiments of the invention will 
15 be discussed as using ACIS. However, the present invention, including each of the 
specific embodiments described herein, may be practiced with other solid modelers. 

Throughout this description, we describe one possible embodiment of the 
invention in which the CAD model being transformed is defined using a boundary 
20 representation. Of course, other shape representations may be used, as long as the 
shape is capable of being represented as a set of surface or curve functions and 
positions. 



25 A. Technical Background 



The principal idea in Space Warping is to allow end users to accurately 
transform the geometry of CAD models through a generalized transformation 
mechanism allowing transformation with any arbitrary function. As shown in FIG, 1, 
CAD applications may represent a shape consisting of faces 30, 40, 50, edges 60, 70 
30 and vertices 80, 90, and its underlying surfaces, edges and positions. The shape of 
figure one consists of a block 10 with a hole in it 20. It has seven faces 30, 40, 50, 
yj fourteen edges 60, 70, and ten vertices 80, 90, two of which are on the hole. The 

underlying geometry of the model therefore has seven surfaces, fourteen curves, and 
ten positions. The topography of the block 10 is such that the front face 30 is 
- 35 connected to the top face 40 at the front, top edge 60. Note that the interior sides of 

the hole, interior face 50, is connected to the front face by the front interior edge 70. 
The front , top edge 60 is a line segment connected between two vertices, the front, 
top left vertex 80, and the front, top right vertex 90. 

40 In a procedural model, a surface in 3-dimensional space is defined in a 

parametric form by a function s from SR 2 to 5R 3 , which maps points from a 2- 
dimensional domain space (u,v) to a 3-dimensional image space (x,y,z). The 
parametric form for a surface may be expressed as: 

x(w,v) 

45 S(u 9 v) = y(u,v) 

z(w,v) 
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Typically, u and v are bounded in some way, for example, 0 <= u <= 1, and 0 <= v <= 
1, finishing the definition of the surface's domain space. The surface function 
determines the geometry of the surface by mapping each point in the domain space 
(u,v) of the function to a corresponding point in 3-dimensional space (x,y,z). The set 
5 of resulting points in (x,y,z) space is the geometry of the surface. 

Similarly, a curve in 3-dimensional space may be defined by a parametric 

function c from 9? 1 to 9? 3 , which maps points from a 1 -dimensional domain space (t) 
to a 3-dimensional image space (x,y,z). Typically, t is also bounded in some way, 
10 such as 0 <= t <= 1 . The parametric form for the curve may be expressed as: c(t) = 
[x(t),y(t), z(t)] 



15 
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c(t)= y(t) 
_z(0_ 

The curve function determines the geometry of the curve by mapping each point in 
the domain space (t) of the function to a corresponding point in 3-dimensional space 
(x,y,z). The set of resulting points in (x,y,z) space is the geometry of the curve. 

Finally, a position defines a precise location in 3-dimensional space (x,y,z). 

B . Transforming the Geometry of a Shape 



Representing the underlying surface and curve geometry of a shape as a set of 
fU 25 functions allows us to easily create a new geometry for the shape by composing these 

tu functions with an arbitrary transformation function. This approach allows a user to 

'H define any arbitrary function, warp the model to view the new geometry and refine the 

NEf warp by altering the transformation function until the desired geometry is achieved. 



30 Transformation of a shape occurs by transforming each point in the geometry 

of a shape by a transformation function f from 9$ 3 to 9* 3 , which takes as input a point 
in (x,y,z) space and transforms that specific point into another location in (x,y,z) 
space, such that f(x,y,z) = {x\y\z') . For example, a transformation function for 
adding a sine wave transformation to the y-coordinate of a shape might be defined as 

35 f(x,y,z) =f( x, y+sin(x), z). In FIG. 2, the block 10 of FIG. 1 is transformed into a new 
block 110 with the ftmction/(3c,>>,z) = (x y y+sin(x)*cos(x), z). It should be noted that 
the topography of the new shape still contains the same faces, edges and vertices 
connected as before, but the geometry underlying that topography has been changed. 
The front face 130 of the new shape is still connected to the top face 140 by the front, 

40 top edge 160, and the front, top edge 160 is still connected between the front, top left 
vertex 180 and the front, top right vertex 190. The only difference between FIG. 1 
and FIG. 2 is that the location of the points underlying the topography in (x,y,z) space 
has changed. 

45 FIGs. 3 and 4 illustrate how a bend transformation affects the curves defining 

a particular surface. FIG. 3 shows how the block 10 of FIG. 1 is transformed into a 
new block 230 using a bend warp, which takes all points in a specified region and 
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warps them into concentric arcs around a particular plane at a specified angle. FIG. 4 
shows a B-spline representation of a surface patch defined by a set of curves 330, 340 
in the domain space (u,v). The resulting curves 350, 360 after the bend 
transformation define the new surface 320. 

5 

The present invention allows the user to easily and accurately transform the 
initial shape by any arbitrary function. Because the underlying geometry of a shape 
may be expressed as a set of functions and positions which define the set of all of the 
points of the geometry, these functions may be easily composed with any 
10 transformation function to create new functions. Function composition involves 
concatenating one function with another function, such that the output value of the 
first function is used as the input value of the second function. An example of a 
composition of two functions from 9? 3 to 9? 3 , where the first function is f i (x,y,z) = 
(x+1, y+1, z+1) and the second function is f 2 (x,y,z) = (x 2 , y 2 , z 2 ) could be expressed 
1 5 either as f 2 ( f 1 (x,y,z) ), or more conveniently as f 2 • f i (x,y,z) = [(x+1) 2 , (y+1) 2 , 
(z+1) 2 ]. 

In order to transform the geometry of a shape by an arbitrary function, the 
functions and positions underlying the existing geometry are simply composed with 
20 the transformation function f(x,y,z). For example, if one of the surfaces of the shape 
can be described by the surface function 

x(w,v) 
y("»v) , 
z(w,v) 

flj 25 and the transformation function f is defined as f(x 5 y,z)= ( x'(x), y'(y),z'(z) ), the new 

ft! surface function sfl will be defined as: 

x r (x(>,v)) 
y ! (y(w,v)) . 

z'(z(w,v))_ 

30 Similarly, if one of the curves of the shape can be described by the curve 

function cl 



sl(w,v) = 



f«sl(x,j\z) = 



cl(t). 



"x(0" 

y(0 

z(0 



35 the new curve function cfl will be defined as: 



£• cl(x 9 y,z) — 



Ax(0)~ 
/(y(0) 

z'(z(0) 
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Once all of the functions defining the surfaces and curves of the shape's 
geometry have been transformed into new surface and curve functions, the geometry 
of the new shape can be easily calculated by taking all points in the domain of each 
original function, and calculating the output value of the corresponding new function. 
5 The positions for the new shape are calculated by passing the original positions of 
each vertex through the transformation function. The resulting set of points is the 
geometry of the new shape. 

C. Method 

10 The basic sequence of space warping is shown in FIG. 5. 

STEP 1 - Obtain a procedural model of a shape by defining surface functions, curve 
functions and positions of the shape. If the shape representation does not define the 
underlying geometry in terms of functions, convert the shape representation to one 
1 5 using underlying functions. 

Sub step 1-1: Define all the surfaces in all faces of the body using surface functions si, 
s2, s3... from 9* 2 to 5H 3 . 

20 Substep 1-2: Define all the curves in all the edges of the body into curve functions cl, 
c2,c3... from 5R 1 to 

STEP 2: Define a transformation function f from 5R 3 to 5R 3 . The transformation 
function f takes a point in (x,y,z) space and transforms it into a new point in (x,y,z) 
25 space. 

STEP 3 - Create new functions and positions by performing function composition 
with the transformation function. 

30 Substep 3-1: Surfaces. 

Given the transformation function f from Step 2, take the function composition 
of each of the functions from Substep 1-1 with f to create a new set of surface 
functions sfl, s£2, sf3 . . . from 9* 2 to 91 3 . 

35 Substep 3-2: Curves. 

Given the transformation function f from Step 2, take the function composition 
of each of the curve functions from step 1 with f to create a new set of curve functions 
cfl,cf2, cf3 ... from 9? 1 to 5H 3 . 

40 STEP 4 - Convert the new functions and positions of Step 3 into the new geometry of 
the shape. 

Substep 4-1: Surfaces. 

Create a new set of surfaces wsl , ws2, ws3 . . . from the functions created in 
Substep 3-1 by taking each of the points in the domain of the original surface 
45 functions (si, s2, s3 .... ) and passing these points through the new surface functions 
(sfl,s£2, sf3 ...). 

Substep 4-2: Curves. 
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Create a new set of curves wcl, wc2, wc3 . . . from the functions created in 
Substep 3-2 by taking each of the points in the domain of the original curve functions 
(cl, c2, c3 .... ) and passing these points through the new surface functions (cfl, cf2, 
cf3 ...). 

5 

Substep 4-3: Positions. 

Pass each of the positions in the vertices of the body through the 
transformation function f to create new positions pfl, pf2, pf3 . . . . 

10 STEP 5 - Reset geometry of CAD model. 

Reset the geometry of the CAD model with the new surfaces (wsl, ws2, ws3 
...), curves (wcl, wc2, wc3 ...) and positions (pfl, pf2, pf3 ...). 

STEP 6 - END? 

15 Display the new geometry of the shape. If the new shape is not satisfactory, 

repeat the method with a refined transformation function. 

D. Specific Implementations of Space Warping 

Examples of specific transformations are shown below. Of course, a user is 
20 not limited to these specific transformations but may use the general function 
composition mechanism to transform the shape with any arbitrary function. 

1 . Twisting 

As shown in FIG. 6, the present invention may be used to perform a twist 
25 transformation on the original block 10 of FIG. 1 . The twisting function operates on 
space by rotating every point in space (or a subset of space) around an axis by a 
specified angle. For example, if the user desires to twist warp a shape by an angle of 
PI radians, the user must first define the axis around which to perform the twist, 
which may be a line or line segment. Next, all the points in space, or the subset of 
30 space defined by planes perpendicular to the start and end points of a line segment, 
will be transformed according to the following transformation function: 

F(x,y,z) = (x*cos(z*PI) -y*sin(z*PI), x*sin(z*PI) + y*cos(z*PI), z ), 

35 2. Bending 

As shown in FIG. 3, the present invention may be used to perform a bend 
transformation on the original block 10 of FIG. 1. The bend function operates on 
space (or a subset of space) by taking all points in a specified region and warping 
them into concentric arcs around a particular plane at a specified angle. 

40 

3. Stretching 

As shown in FIG. 7, the present invention may be used to perform a stretching 
transformation on the original block 10 of FIG. 1. The stretch function operates on 
space by translated each point in the specified region by a certain distance in the 
45 direction of a unit vector, without affecting the point's position along the other axes. 

The foregoing disclosure of embodiments of the present invention has been 
presented for purposes of illustration and description. It is not intended to be 
exhaustive or to limit the invention to the precise forms disclosed. Many variations 
50 and modifications of the embodiments described herein will be obvious to one of 
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ordinary skill in the art in light of the above disclosures. The scope of the invention 
to be defined only by the claims appended hereto, and by their equivalents. 
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We claim: 

1 . A method for using surface and curve functions and positions in a CAD model 
to define the geometry of a shape to allow the transformation of the shape with 
an arbitrary function, said method comprising the steps of: 

5 

a. Obtaining a solid model containing one or more faces, edges and/or vertices, 
where the underlying geometry of each face, edge or vertex may be 
represented, respectively by a surface, curve, or position, and each surface or 
curve may be represented by a function mapping from a domain space into 3- 

10 dimensional space; 

b. Defining a transformation function mapping from 3-dimenional space to 3- 
dimensional space; 

15 c. Creating new surface and curve functions by performing function composition 
with each of the existing surface and curve functions with the transformation 
function; 

d. Creating new, surfaces and curves by taking each point in the domain of each 
20 of the original surface and curve functions and passing the point through the 

corresponding new function, and creating new positions by passing each 
original position through the transformation function; and 



r.i 25 



Resetting the geometry of the CAD model. 
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ABSTRACT 

Methods for the transformation of shapes in Computer Aided Design (CAD) 
applications applying a general function composition mechanism with any arbitrary 
function. This method allows the geometry of a shape to be transformed by any 
generic function while maintaining the topography of the shape. To enable this 
transformation, the underlying geometry of a shape must either be expressed in terms 
of surface and curve functions and positions underlying the faces, edges and vertices 
respectively of the shape, or be capable of being converted into such a representation. 

Once the underlying geometry of the shape has been represented as a set of 
functions and positions, the functions are composed with an arbitrary transformation 
function to define new surface and curve functions. The positions are merely passed 
through the transformation function. Once the new functions and positions have been 
created, the geometry of the transformed shape can be found by passing each point in 
the domain of each original geometry function through the new transformed function. 
The resulting set of points is the geometry for the transformed shape. This shape may 
then be displayed to the user, and the steps of this method repeated for refinement of 
the transformation function. 
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